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commerce server contacts a selected payment system and completes the electronic commerce transaction. The commerce server then notifies 
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METHOD AND SYSTEM FOR CONDUCTING 
ELECTRONIC COMMERCE TRANSACTIONS 

Cross-Reference to Related Application 

5 This application is a continuation-in-part of U.S. Provisional Application No. 

60/054,121, filed July 29,1997. 

Background 

Fin n of the Invention 

This invention pertains in general to electronic commerce and in particular to a method 
10 and system for conducting electronic payment transactions via the Internet. 

FUryr.Roi iND of the Invention 

Electronic commerce conducted over the Internet has become increasingly important 
over the last decade. Online merchants offer goods and services for sale or rent including 

1 5 physical objects such as compact disks, books, and clothing, and intellectual property such as 
streaming music and movies and electronic books. Physical items may be delivered to the 
customer via the mail or a variety of other shipping options. Intellectual property, in contrast, 
may be delivered to the customer by allowing a download via the file transfer protocol 
■("FTP"), providing the customer with an access key, establishing a telnet session, or through 

20 some other form of electronic delivery. 

Typically, these goods and services are displayed on the merchant's web site and a 
prospective customer views, selects, and purchases the goods using web browsing software 
such as NETSCAPE NAVIGATOR* The customer usually pays for a product by establishing 
a secure connection with the merchant's web server and transmitting payment information, 

25 such as a credit card number, to the merchant. The merchant then uses back-end processing to 
verify the payment information and receive payment. For example, the merchant may use a 
secure telephone line or network link to contact the credit card issuer before accepting the 
customer's order. Eventually, the merchant and credit card issuer settle payment and the 
merchant delivers the product or service to the customer. 

30 A difficulty with the above-described scenario is that each merchant must implement an 

inventory and payment database and a payment acceptance and verification system. For 
example, the merchant must establish and maintain a database tracking sales, delivery, and 
payment information and product inventories in order to support the electronic commerce 
system. There is significant cost and complexity in maintaining this database, including the 

35 difficulty of integrating it with legacy accounting and fulfillment systems and aggravated by 
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the scarcity of truly skilled personnel. In addition, the merchant must design web pages to 
securely accept the order and payment information and implement the functionality to verify ' 
the payment. These tasks can be extremely difficult if the merchant accepts payment using 
many different methods, such as credit cards and electronic fund transfers, or accepts payment 

5 in more than one currency. Moreover, having a large number of separate payment acceptance 
systems on the Internet provides a greater opportunity for fraud and abuse because the flaws of 
each system can be exploited. 

Although Internet-based electronic commerce clearinghouses have been developed to 
handle transactions from many different parties, these clearinghouses do not provide a 

10 convenient interface to the merchant. In addition, the merchant must still establish the 
payment, verification, and database systems described above. 

Accordingly, there is a need in the art for a method and system for conducting 
electronic commerce on the Internet which reduces the amount of work that must be performed 
by the online merchant. Preferably, the method and system will allow the merchant to easily 

15 and verifiably perform inventory, sales, and delivery tracking and transparently support 
different types of payments and currencies. 

Summary of the Invention 

The above needs are met by a method and system for conducting electronic commerce 
20 transactions that allows a merchant to easily sell a mix of physical and intangible items and 

supports sales, inventory, and delivery tracking and a variety of payment systems by having the 
merchant establish an account on a commerce server. The commerce server provides the 
merchant with inventory, accounting, and order management systems. Furthermore, the 
commerce server allows merchants to conduct electronic commerce with other merchants and 
25 vendors. 

The commerce server includes a web server providing web pages to the merchant. By 
usine these web pages, the merchant establishes an account on the commerce server. Then, the 
merchant provides the commerce server with information about an item sold by the merchant, 
such as a plane ticket, clothing, a book, a software product, or playing time with an online 
30 game. The merchant also provides the commerce server with other attributes of the item from 
which the customer may select, for example, the quantity or duration of an item. In addition, 
the merchant supplies payment processing rules defining the payment options that are 
acceptable to the merchant, such as which currencies and payment systems are allowed and 
when or how often to bill the customer. 
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The commerce server preferably stores the information received from the merchant in 
an entry of a database. In one embodiment, the database entry categorizes the item as a hard - 
good, soft good, or online good depending upon the delivery options available for the item. 
The commerce server, in addition, provides the merchant with a "payment button" including a 
5 universal resource locator ("URL") that points to the commerce server and includes 
information allowing the commerce server to identify the database entry with which the 
payment button is associated. The merchant preferably publishes the payment button on the 
merchant's web site. 

The customer selects the payment button when the customer wishes to purchase the 

1 0 associated product. In response, the customer's computer is automatically directed to the web 
server managed by the commerce server and provided with the item information entered by the 
merchant. In addition, the customer is presented with the payment options allowed by the 
merchant's payment processing rules. Preferably, the customer then provides the web server 
with the payment information necessary to complete the transaction. 

15 When the merchant's payment terms specify that payment is required, the commerce 

server preferably identifies the remote payment system selected by the customer and contacts it 
to complete the electronic commerce transaction. Preferably, a module within the commerce 
server converts calls generated by the commerce server into the format used by the selected 
payment system. Likewise, the module converts responses received from the payment system 

20 into the format used by the commerce server. Then, the commerce server notifies the customer 
and the merchant of the result of the electronic commerce transaction and, if appropriate, 
delivers the item using one of the delivery options specified in the database. 

A method of conducting electronic commerce between a remote customer and a remote 
merchant in accordance with the present invention includes receiving information identifying 

25 an item to be purchased by the customer, receiving payment information specifying a payment 
method to be used by the customer to purchase the item, conducting a payment transaction 
with a remote payment system specified by the payment information, and providing the 
customer and the merchant with the result of the payment transaction. 

Similarly, computer program instructions for conducting electronic commerce 

30 transactions in accordance with the present invention include instructions for storing item 
information received from the merchant, instructions for issuing the merchant a reference to 
the stored item information, instructions for receiving an electronic commerce transaction 
identifier from the customer containing the reference to the stored item information issued to 



3 
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the merchant, instructions for accepting payment information from the customer, and 
instructions for conducting the electronic commerce transaction with a remote payment system. 

Brief Description of the Drawings 

5 FIGURE 1 is a high-level block diagram of an electronic commerce system according 

to an embodiment of the present invention; 

FIGURE 2 is a high-level block diagram illustrating functional components of a 
commerce server according to an embodiment of the present invention; 

FIGURE 3 is a high-level block diagram of an entry in a database associated with the 
1 0 commerce server according to an embodiment of the present invention; 

FIGURE 4 is a flow diagram illustrating the interactions between the customer, 
merchant, commerce server, and payment system when completing a payment transaction 
according to an embodiment of the present invention; and 

FIGURE 5 illustrates an exemplary screen display of-a web page seeking payment 
15 information from a customer; and 

FIGURE 6 illustrates an exemplary screen display of an order confirmation web page. 

Detailed Description of the Preferred Embodiment 

As used herein, the "Internet" refers to the global network of interconnected computer 
20 systems and the "World Wide Web" ("WWW") refers to the global hypertext system using the 
Internet as its transport mechanism. A "universal resource locator" ("URL") is a reference to a 
piece of information or a software function on a computer connected to the Internet. A "web 
server" is a program that accepts requests for information framed according to the Hypertext 
Transport Protocol ("HTTP"). "Web pages" are the information supplied by the web server in 
25 response to the requests. The Common Gateway Interface ("CGI") is the standard that 

describes how the web server accesses external programs, usually called "CGI programs" or 
"CGI scripts," called by a web page. Of course, the present invention is not limited to the 
Internet and may be used with any digital network supporting electronic commerce. In a non- 
Intemet-based system, the terms defined above also include the non-Internet-based equivalents 
30 for communicating between the various entities described herein. 

FIG. 1 is a high-level block diagram of an electronic commerce system 100 according 
to an embodiment of the present invention. Illustrated are a customer computer (sometimes 
referred to as "the customer") 1 10, a merchant web server (sometimes referred to as "the 
merchant") 1 12, and a commerce server ("CS") 1 14, all coupled to the Internet 116. In a 

4 
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typical embodiment, the customer computer 1 10 is a personal computer having, among other 
things, a processor, memory, storage device, and monitor. The customer computer 1 10 is - 
coupled to the Internet 1 16 via a network connection 118. The network connection may be, for 
example, a modem coupled to an analog telephone line, a digital subscriber line, a cable 

5 modem utilizing bandwidth on a cable television coaxial cable, a high speed digital line, or any 
other communications medium. Web browsing software, such as NETSCAPE 
NAVIGATOR*, preferably executes on the client computer and sends data from the client 
computer 1 1 0 to the merchant web server 1 1 2 via the network connection 1 1 8 and Internet 
116. In another embodiment, the customer computer 1 10 is a palm-top device or personal 

1 0 digital system communicating via radio waves with the Internet 1 1 6 or another electronic 
commerce system. 

The merchant web server 1 12 is preferably similar to the customer computer 110 except 
that it is has the processing power and communications 1 16 bandwidth to handle multiple 
simultaneous customer transactions. The merchant 1 12 sells items, such as merchandise, 

1 5 information, intellectual property, and/or services via a web site hosted on the merchant web 
server 1 12. The merchant's 1 12 web site may, for example, display a catalog of software 
available for purchase, allow the customer 1 10 to view flight schedules and purchase a plane 
ticket, or allow the customer 1 10 to play an online game, download a book or music, or access 
a database of information. 

20 As used herein, the terms "customer" and "merchant" depend upon the specific 

transaction being conducted. In a chain of commerce transactions, the "customer" in a first 
transaction may be a "merchant" in a second transaction. For example, the customer 1 10 may 
buy components of a product from several different vendors or merchants 1 12 using the 
electronic commerce system described herein and then, in turn, sell the combined product via 

25 the customer's own web site and the CS 114. 

The merchant's web site displays at least one "payment button." A payment button is a 
graphic button, a region of a larger graphic, a text string, or another form of URL link which 
the customer 1 10 may "press" by selecting it with a mouse, physical button, or other input 
device. In another embodiment, the payment button may be utilized on a non-Intemet-based 

30 electronic commerce system. In such an embodiment, the payment button is considered to be 
"pressed" whenever a customer 110 expresses a desire to purchase an item. As described 
below, the payment button is pressed by the customer 1 10 when the customer 1 10 wishes to 
purchase and pay for an item displayed for sale on the merchant's web site. In a preferred 
embodiment, every type of item for sale on the merchant's web site has a separate payment 

5 
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button. When a customer 1 10 wishes to purchase the product, the 1 10 customer presses the 
product's associated payment button. Then, the customer 1 10 is preferably presented with a ' 
menu allowing the customer 110 to specify attributes, such as quantity or duration, of the items 
that the customer 1 10 wishes to purchase. 
5 In another embodiment, the merchant web site has only one payment button or has only 

one payment button for each class of items for sale. In this embodiment, the customer 1 10 is 
preferably presented with a menu of choices after pressing the payment button. For example, 
the menu of choices may ask the customer 1 10 to identify a specific product or an attribute of a 
product, like color, that the customer 1 10 wishes to purchase. 
1 o Every payment button has an associated URL that points to information in the CS 114. 

Preferably, a database key that uniquely identifies the merchant 112 and/or item for sale is 
encoded within the URL. When the customer 1 10 presses the payment button, the customer 
1 10 is redirected to a web page provided by the CS 1 14 and specific to the merchant 1 12 
and/or item. 

1 5 in one embodiment, the CS 1 14 queries the customer for the quantity or duration of the 

item that the customer 1 10 wishes to purchase and payment information. The CS 1 14 receives 
the customer's responses and conducts the electronic commerce transaction according to 
payment processing rules and delivery options specified by the merchant 112. The CS 1 14 
records the transaction in its database and notifies the customer and merchant whether the 

20 transaction was successful. Accordingly, the merchant 1 12 is relieved of the responsibility of 
conducting the electronic commerce transaction with the customer 1 10. 

FIG. 2 is a high-level block diagram illustrating functional components of the CS 114 
and also illustrating a remote payment system 222 and a remote merchant 223 according to a 
preferred embodiment of the present invention. The CS 1 14 is preferably similar to the 

25 customer 1 1 0 and merchant 1 12 computers, except that the CS 1 1 4 has enough processing 

power and Internet 116 bandwidth to support many simultaneous payment button transactions 
as described herein. The functionality of the CS 1 14 described herein may be performed by 
hardware or software modules within the CS 1 14. In one embodiment of the present invention, 
the functionality of the CS 1 14 is provided by software applications executing on INTEL x86- 

30 or SUN MICROSYSTEMS SPARC-compatible hardware under control of MICROSOFT 
WINDOWS NT or a derivative of the UNIX operating system, such as SOLARIS 2.5.1. In 
another embodiment of the present invention, the functionality of the CS 1 14 is provided by a 
distributed computing system as described below. 

6 
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The remote payment system 222 is preferably a third-party payment gateway or system. 
The gateway or system is preferably connected to a financial transaction network, which, in * 
turn, typically links to computers at banks and other financial institutions for approval and 
settlement of electronic commerce transactions. Typical gateways or systems may include 
5 CYBERCASH, e-CASH, MONDEX, or SET. While only one payment system 222 is 
illustrated in FIG. 2, the CS 1 14 may be in communication with many different remote 
payment systems 222, either through a secure link on the Internet 1 1 6 or a dedicated secure , 
link. Each payment system has an applications programming interface ("API"). By using the 
API, the CS 1 1 4 communicates with the payment system 222 and performs secure and 

1 0 verifiable payment transactions. 

The remote merchant 223 is preferably a merchant selling items via a web site as 
described above. The remote merchant 223 may have an account on the CS 1 1 4 or the 
merchant 223 may have an interface for selling items similar to the remote payment system 
222. In general, the remote merchant 223 is included in FIG. 2 to illustrate that the customer's 

15 110 electronic commerce transaction performed by the CS 1 14 may contact a remote payment 
system 222 and/or a remote merchant 223. 

The CS 1 14 includes a payment button transaction engine 210 which is coupled to a 
database 212 and a web server 214. A firewall 216 preferably sits between the web server 216 
and the transaction engine 210. While these functional components are illustrated in FIG. 2 as 

20 discrete entities, the CS 1 14 may be executed on a distributed computer system having a 
plurality of engines, databases, and web servers working together the perform the functions 
described herein. For example, one embodiment of the CS 1 14 uses multiple transaction 
engines 210 and web servers 214 and a single distributed database 212, thereby providing 
scalability to the CS 1 14. The number of web servers 214 and transaction engines 210 depends 

25 on the actual system load and the desire to achieve better performance through balancing the 
transaction load across the system. 

The payment button transaction engine 210 includes a rules module 218 that controls 
the interactions and flows of information necessary to complete a payment transaction. In 
addition, the transaction engine 210 preferably includes a Payment Application Programming 

30 Interface ("PAPI") module 220 enabling communication between the CS 1 14 and the remote 
payment systems 222 and merchants 223. The PAPI module 220 abstracts the different APIs 
of each payment system 222 and merchant 223 into a single, higher level, PAPI that can 
interface with each of the payment systems 222 and merchants 223. The transaction engine 
210 performs payment transactions with a payment system 222 or merchant 223 by making 
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calls to the PAPI. The PAPI abstraction module 220 translates these calls into the specific API 
of the payment system 222 or merchant 223 being used for that transaction. The PAPI 
abstraction module 220 also translates data received from the payment system 222 or merchant 
223 into the format utilized by the transaction engine 210. Accordingly, the PAPI abstraction 
5 module 220 allows support for new payment systems 222 and merchants 223 to be added to the 
CS 1 14 by merely creating a new PAPI to payment system or merchant API mapping in the 
PAPI abstraction module 220. 

The payment button store module ("PB store") 224, in combination with the web server 
214, allows a merchant 1 12 to obtain a payment button. The web server 214 is preferably an 

1 0 industry standard web server such as the NETSCAPE ENTERPRISE SERVER or the 

APACHE web server. The web server 214 provides secure communication with the customer 
1 10 and preferably uses industry standard technologies including HyperText Markup Language 
("HTML"), and HTTP to deliver information to the customer 110. In addition, the web server 
preferably uses industry standard encryption techniques, including secure HTTP ("S-HTTP") 

1 5 and the secure sockets layer ("SSL"), to ensure that communications with the customer 1 1 0 are 
private. The firewall 216 allows only authorized communications between the web server 214 
and the transaction engine 210 and ensures that a malicious user cannot access or corrupt the 
transaction engine 210. 

The PB store 224 allows the merchant to purchase payment buttons and add product 

20 descriptions, merchant configurations, and other information to the database 212. In a 

preferred embodiment of the present invention, the merchant 112 accesses the PB store through 
a web site on the web server 214. The PB store module 224 captures the merchant 1 12 actions 
on the web server 214 and creates the appropriate entries in the database 212. 

In one embodiment of the present invention, the PB store web site describes the 

25 payment button mechanism, the services offered by the payment button vendor, and the costs 
of the services. In addition, the web site preferably has a merchant registration form 226 for 
registering new merchants, a merchant renewal form 228 for renewing merchant registrations, 
and a payment button generation form 230 for issuing payment buttons to registered 
merchants. The forms preferably include CGI programs for performing the functionality 

30 described herein. 

The merchant registration form 226 allows the merchant 1 12 to input information 
identifying the merchant 1 12 and includes a payment button with which the merchant 1 12 can 
pay a registration fee. After the fee payment is verified, the merchant 1 12 is preferably issued 
a login/password pair and an account with the CS 1 14 through which the merchant 1 12 can 
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access the payment button generation form and maintain the merchant's account. Similarly, 
the merchant renewal form 228 preferably includes a payment button with which the merchant 
1 12 can pay a renewal fee. 

The payment button generation form 230 allows the merchant 1 12 to enter item 
5 description data, such as item names and descriptions, prices, types, and delivery options, and 
payment processing rules, such as supported credit cards, payment systems, and currencies. In 
addition, the payment processing rules may rank the payment systems in order of preference, 
describe when payment is required (e.g., the merchant may require billing after 90 days), 
and/or describe the quantity or duration of an item available for a certain price. In one 

10 embodiment of the present invention, the merchant 112 enters the item description data and 
pavment processing rules by uploading a file to web site having the information in a 
standardized format. c 

When entry of this data is completed, the payment button generation form 230 sends 
the data to the transaction engine 210, which stores the information in the database 212 at a 

15 location specified by a key. The transaction engine 210 passes the key back to the PB store 
web site, which provides the merchant with a payment button download page displaying the 
results of the payment button generation transaction. If the transaction was successful, the 
payment button download page includes the payment button issued to the merchant 1 12. The 
payment button has an associated URL that specifies the key. Accordingly, little or no 

20 engineering effort is required to maintain each merchant configuration on the CS 114. 

In one embodiment of the present invention, there are multiple PB store web sites 
communicating with the database 212 through the transaction engine 210. When a payment 
button is created, the transaction engine 210 creates a field in the database 212 entry specifying 
the PB store that generated the payment button. Accordingly, payment buttons may be 

25 "branded" among different payment button vendors. 

The database 212 is preferably a robust relational database. A preferred embodiment of 
the present invention uses the ORACLE 7 database to implement the functionality described 
herein. The database 212 stores item descriptions, payment processing rules, and other 
information necessary to complete a payment transaction on behalf of a merchant 1 12. This 

30 merchant information is preferably accessed in the database by using a key assigned to each 
merchant 1 12 and/or item for sale. The database 212 is also used as a repository of transaction 
information including authorization logs, payment status and completion records, and other 
information required by the merchant 1 12 and the CS 114. 

9 
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FIG. 3 is a high-level block diagram of functional components within the database 212. 
Illustrated therein are a database entry 300 including a primary entry 310 linked to at least one 
of three types of item entries 312, 314, 316. The primary entry 310 is the entry identified by 
the key provided to the merchant 112. Accordingly, the primary entry 310 is typically 
5 accessed either when the merchant 112 provides the key while using the PB store web site or 
when the customer 1 10 uses the URL provided by a payment button to purchase the item 
identified in the database entry 310. 

The primary entry 3 1 0 contains a field 3 1 8 storing the payment processing rules for the 
item as specified by the merchant 1 1 2 through the PB store. The primary entry 3 1 0 also 
1 0 contains a field 320 holding item type information as specified by the merchant 1 12. The item 
type information preferably describes the item attributes input by the merchant 112. In 
addition, the item type information field 320 preferably contains at least one link to another 
database entry 312, 314, 316 describing delivery options for the item. 

The available delivery options for an item depend upon the type of item. FIG. 3 
15 illustrates three database entries 312, 314, 316 describing delivery options for hard, soft, and 
online items. However, an embodiment of the present invention may have many different 
types of items and corresponding delivery options. A hard item is typically a manufactured 
physical product such as clothing, a book, or a machine part. Accordingly, the entry 312 
holding delivery options 322 may list various shipping methods and companies available for 
20 delivering the hard item to the customer 110. 

A soft item, in contrast, is typically intangible intellectual property such as music, 
electronic books, or software. For example, the soft item may be a streaming music file that 
can be played by the customer 1 10. Accordingly, the entry 314 holding delivery options 324 
may list a URL or electronic key that can be provided to the customer to effectuate the 
25 purchase. For example, the options 324 may provide instructions for initiating an FTP session 
to download the purchased soft item to the customer's 1 10 computer system. 

An online item is typically access to an online service or other software executing 
remotely from the customer 1 10. For example, the online item may be access to an electronic 
database of information or an online game. Accordingly, the entry 316 holding delivery 
30 options 326 preferably includes instructions for allowing the customer 1 10 to access the online 
item. For example, the options 326 may provide instructions for initiating a telnet session with 
an electronic database for a limited duration of time. 

FIG. 4 is a flow diagram illustrating the interactions between the customer 110, 
merchant 1 12, CS 1 14, database 212 and a payment system 222 when completing a payment 

10 
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transaction according to a preferred embodiment of the present invention. In the flow diagram, 
time flows from the top of the diagram to the bottom and horizontal lines represent 
communications between the various entities. FIG. 4 illustrates only major interactions 
between the entities and does not represent every interaction. In addition, FIG. 4 illustrates a 
5 simple case of the present invention wherein the merchant's 1 1 2 payment processing rules 
specify that the payment transaction should be processed at the time the customer's 1 10 order 
is received. 

Initially, the customer 1 10 is browsing the merchant's web site and decides to purchase 
an item by pressing 4 1 0 the associated payment button. In response to the press, the 

10 merchant's web server 1 12 redirects 412 the customer's browser to the location on the CS 1 14 
specified by the URL associated with the payment button. The customer's browser fetches 414 
the referenced page from the CS 1 14. 

The CS 1 14 parses the URL received from the customer 1 10 for the database 212 key 
corresponding to the item that the customer 1 10 wishes to* purchase. Using this key, the CS 

15 114 accesses 4 1 6 the database 2 1 2 and dynamically generates a web page indicating the 
attributes and payment options available for the item as defined by the merchant 112. In 
addition, the CS 1 1 4 preferably determines the language utilized by the customer 1 10 and 
currencies supported by the merchant 1 12 and modifies the web page accordingly. This 
generated web page is sent 418 to the customer 110. FIG. 5 illustrates an exemplary screen 

20 display 500 of the web page seeking payment information from the customer 1 10. 

The customer selects the desired item attributes and payment service, enters any 
necessary payment information, such as a credit card or account number, and transmits 420 
these data to the CS 1 14. The CS 1 14 stores 422 the received data in the database 212 and 
contacts the selected payment system 222. As described above, the CS 1 14 preferably uses the 

25 PAPI module 220 to translate transaction calls made by the transaction engine 210 into the API 
of the selected payment system 222. The CS 1 14 preferably stores 426 records of all 
communications with the payment system 222, customer 1 10, and merchant 1 12 in the 
database 212. Therefore, the database 212 can be used to reconstruct transaction histories in 
order to provide error tracking and accounting services. If the payment system 222 rejects the 

30 transaction, the CS 1 14 publishes a web page to the customer indicating this result and 
presenting alternative payment methods, if any (this interaction is not shown in FIG. 4). 

If the payment system 222 approves the transaction, the CS dynamically generates a 
web page containing payment status information and publishes 428 this information to the 
customer 110. This page preferably contains a receipt or confirmation number generated by 
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the CS 1 14. In a preferred embodiment of the present invention, the confirmation number is a 
unique number encoding transaction, session, and merchant identifications and a time and date 
stamp. This confirmation number is preferably a key to a database entry holding the 
transaction information and can be used later by the merchant 1 12 and customer 1 10 to confirm 
payment, to query the CS 1 14 for payment status information, and to use the CS 1 14 to query 
the payment system for account status information. The web page also preferably contains any 
other information required by the merchant 1 12 and a link to a confirmation page on the 
merchant's web site 1 12. FIG. 6 illustrates an exemplary screen display 600 of an order 

confirmation web page. 

The CS 1 14 also notifies 428 the merchant 1 12 that payment was accepted and provides 
. the same receipt or confirmation number as was provided to the customer 1 10. In one 
embodiment, this notification is performed via a secure electronic mail message. Accordingly, 
both the customer 1 1 0 and merchant 1 12 are notified that the purchase was made. 

Finally, the customer 1 10 fetches 430 the confirmation web page on the merchant's 
web site. Preferably, this web page provides the customer 1 10 with additional information 
about the purchase or any other information which the merchant 1 12 desires to provide. 

In summary, the present invention is a system, method, and computer program 
instructions for conducting electronic commerce transactions via the Internet or any electronic 
communication system. The merchant 112 opens an account on the CS 1 14 and supplies 
information about items sold by the merchant 1 12. The CS 1 14 stores this information in a 
database 212 entry and issues the merchant 1 12 a URL containing the key to database entry. 
The merchant 112 supplies this URL to customers wishing to purchase an item, causing a 
customer 1 10 to be connected to the CS 1 14. The CS 1 14 collects payment information from 
the customer 110, conducts the electronic commerce transaction with a remote payment system 
222. and notifies the customer 1 10 and merchant 112 of the result. 
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Claims 

I claim: 

1 . A computer system for supporting electronic commerce transactions between a 
customer and a remote merchant, the computer system comprising: 

5 a database having an entry including merchant information identifying an item 

offered for sale by the remote merchant; and 
a transaction engine in communication with the database and a remote payment 
system for performing an electronic commerce transaction, the transaction 
engine comprising: 

10 a first module for receiving an electronic commerce transaction identifier 

from the customer, the electronic commerce transaction identifier 

specifying the entry in the database; 
a second module for accepting payment information from the customer, the 

payment information identifying the remote payment system; and 
15 a third module for performing the electronic commerce transaction with the 

remote payment system using the payment information received 

from the customer. 

2. The computer system of claim 1, wherein the transaction engine further 
comprises: 

20 a fourth module for notifying the remote merchant and the customer of a result of 

the electronic commerce transaction. 

3. The computer system of claim 1, further comprising: 

a web server in communication with the transaction engine for communicating with 
the remote merchant and customer; and 
25 a firewall between the web server and the transaction engine for securing 

communications between the web server and the transaction engine. 

4. The computer system of claim 3, wherein the transaction engine further 
comprises: 

a fifth module for dynamically generating a web page from the entry in the database 
30 and providing the web page to the customer via the web server, the web 

page providing information about the item offered for sale by the remote 
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merchant and facilitating collection of the payment information from the 
customer. 



5. The computer system of claim 3, wherein the computer system further 
comprises: 

a sixth module for accepting the merchant information identifying the item offered 
for sale by the remote merchant via the web server, creating the database 
entry for holding the merchant information, and providing the remote 
merchant with a reference to the database entry. 

6. The computer system of claim 1 , wherein the electronic commerce transaction 
identifier is a URL identifying the computer system and including a key to the entry in the 
database. 

7. The computer system of claim 1 , wherein the database further comprises: 

an entry specifying payment processing rules defined by the remote merchant; and 
an entry specifying delivery options for the item offered for sale by the remote 
merchant. 

8. The computer system of claim 1 , wherein there are a plurality of available 
remote payment systems and wherein the second module for accepting payment information 
from the customer accepts payment information identifying one of the available remote 
payment systems. 

9. The computer system of claim 1, wherein the transaction engine is executed by 
a plurality of distributed computer systems. 

10. A method of conducting electronic commerce between a remote customer and \ 
remote merchant, the method comprising the steps of: 

receiving information identifying an item to be purchased by the remote customer; 
receiving payment information specifying a payment method to be used by the 

remote customer to purchase the item; 
conducting a payment transaction with a remote payment system specified by the 

payment information; and 
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providing the remote customer and the remote merchant with a result of the 
payment transaction. 

11. The method of claim 10, further comprising the steps of: 

receiving information about the item to be purchased from the remote merchant; 
5 storing the information about the item to be purchased at a specified location; and 

providing the remote merchant with a reference to the specified location. 

12. The method of claim 1 1 , wherein the remote merchant provides the reference to 
the specified location to the remote customer responsive to the remote customer desiring to 
purchase the item. 

10 13. The method of claim 1 0, further comprising the step of: 

providing the remote customer with a list of item attributes from which the 
customer can select. 

14. The method of claim 10, wherein the step of receiving information identifying 
the item to be purchased by the remote customer comprises the steps of: 

15 receiving payment processing rules specifying payment options available for 

purchasing the item; and 
receiving delivery options for the item. 

1 5. A computer-readable medium having computer instructions encoded thereon for 
conducting electronic commerce transactions between a remote merchant and a remote 

20 customer, the computer instructions comprising: 

instructions for storing item information received from the remote merchant; 
instructions for issuing the remote merchant a reference to the stored item 
information; 

instructions for receiving an electronic commerce transaction identifier from the 
25 remote customer containing the reference to the stored item information 

issued to the remote merchant; 
instructions for accepting payment information from the remote customer, the 

payment information identifying a remote payment system; and 
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instructions for conducting the electronic commerce transaction with the remote 
payment system using the payment information received from the remote ' 
customer. 

16. The computer- readable medium of claim 15, wherein the instructions further 
5 comprise: 

instructions for notifying the remote merchant and the remote customer of a result 
of the electronic commerce transaction. 

17. The computer-readable medium of claim 15, wherein the instructions for storing 
item information received from the remote merchant comprise: 

10 instructions for receiving payment processing rules from the remote merchant 

specifying payment options for the electronic commerce transaction; and 
instructions for receiving delivery rules from the remote merchant specifying 
delivery options for the electronic commerce transaction. 
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METHOD AND SYSTEM FOR CONDUCTING 
ELECTRONIC COMMERCE TRANSACTIONS 

Cross-Reference to Related Application 

5 This application is a continuation-in-part of U.S. Provisional Application No. 

60/054,121, filed July 29, 1997. 

Background 

Ftf.t.d of the Invention 

This invention pertains in general to electronic commerce and in particular to a method 
10 and system for conducting electronic payment transactions via the Internet. 

Background of the Invention 

Electronic commerce conducted over the Internet has become increasingly important 
over the last decade. Online merchants offer goods and services for sale or rent including 

15 physical objects such as compact disks, books, and clothing, and intellectual property such as 
streaming music and movies and electronic books. Physical items may be delivered to the 
customer via the mail or a variety of other shipping options. Intellectual property, in contrast, 
may be delivered to the customer by allowing a download via the file transfer protocol 
("FTP"), providing the customer with an access key, establishing a telnet session, or through 

20 some other form of electronic delivery. 

Typically, these goods and services are displayed on the merchant's web site and a 
prospective customer views, selects, and purchases the goods using web browsing software 
such as NETSCAPE NAVIGATOR*. The customer usually pays for a product by establishing 
a secure connection with the merchant's web server and transmitting payment information, 

25 such as a credit card number, to the merchant. The merchant then uses back-end processing to 
verify the payment information and receive payment. For example, the merchant may use a 
secure telephone line or network link to contact the credit card issuer before accepting the 
customer's order. Eventually, the merchant and credit card issuer settle payment and the 
merchant delivers the product or service to the customer. 

30 A difficulty with the above-described scenario is that each merchant must implement an 

inventory and payment database and a payment acceptance and verification system. For 
example, the merchant must establish and maintain a database tracking sales, delivery, and 
payment information and product inventories in order to support the electronic commerce 
system. There is significant cost and complexity in maintaining this database, including the 

35 difficulty of integrating it with legacy accounting and fulfillment systems and aggravated by 
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the scarcity of truly skilled personnel. In addition, the merchant must design web pages to 
securely accept the order and payment information and implement the functionality to verify , 
the payment. These tasks can be extremely difficult if the merchant accepts payment using 
many different methods, such as credit cards and electronic fund transfers, or accepts payment 
in more than one currency. Moreover, having a large number of separate payment acceptance 
systems on the Internet provides a greater opportunity for fraud and abuse because the flaws of 

each system can be exploited. 

Although Internet-based electronic commerce clearinghouses have been developed to 
handle transactions from many different parties, these clearinghouses do not provide a 
convenient interface to the merchant. In addition, the merchant must still establish the 
payment, verification, and database systems described above. 

Accordingly, there is a need in the art for a method and system for conducting 
electronic commerce on the Internet which reduces the amount of work that must be performed 
by the online merchant. Preferably, the method and system will allow the merchant to easily 
15 and verifiably perform inventory, sales, and delivery tracking and transparently support 
different types of payments and currencies. 



10 



Summary of the Invention 
The above needs are met by a method and system for conducting electronic commerce 
20 transactions that allows a merchant to easily sell a mix of physical and intangible items and 

supports sales, inventory, and delivery tracking and a variety of payment systems by having the 
merchant establish an account on a commerce server. The commerce server provides the 
merchant with inventory, accounting, and order management systems. Furthermore, the 
commerce server allows merchants to conduct electronic commerce with other merchants and 
25 vendors. 

The commerce server includes a web server providing web pages to the merchant. By 
using these web pages, the merchant establishes an account on the commerce server. Then, the 
merchant provides the commerce server with information about an item sold by the merchant, 
such as a plane ticket, clothing, a book, a software product, or playing time with an online 
30 game. The merchant also provides the commerce server with other attributes of the item from 
which the customer may select, for example, the quantity or duration of an item. In addition, 
the merchant supplies payment processing rules defining the payment options that are 
acceptable to the merchant, such as which currencies and payment systems are allowed and 
when or how often to bill the customer. 
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The commerce server preferably stores the information received from the merchant in 
an entry of a database. In one embodiment, the database entry categorizes the item as a hard 
good, soft good, or online good depending upon the delivery options available for the item. 
The commerce server, in addition, provides the merchant with a "payment button" including a 
5 universal resource locator ("URL") that points to the commerce server and includes 
information allowing the commerce server to identify the database entry with which the 
payment button is associated. The merchant preferably publishes the payment button on the 
merchant's web site. 

The customer selects the payment button when the customer wishes to purchase the 

10 associated product. In response, the customer's computer is automatically directed to the web 
server managed by the commerce server and provided with the item information entered by the 
merchant. In addition, the customer is presented with the payment options allowed by the 
merchant's payment processing rules. Preferably, the customer then provides the web server 
with the payment information necessary to complete the transaction. 

1 5 When the merchant's payment terms specify that payment is required, the commerce 

server preferably identifies the remote payment system selected by the customer and contacts it 
to complete the electronic commerce transaction. Preferably, a module within the commerce 
server converts calls generated by the commerce server into the format used by the selected 
payment system. Likewise, the module converts responses received from the payment system 

20 into the format used by the commerce server. Then, the commerce server notifies the customer 
and the merchant of the result of the electronic commerce transaction and, if appropriate, 
delivers the item using one of the delivery options specified in the database. 

A method of conducting electronic commerce between a remote customer and a remote 
merchant in accordance with the present invention includes receiving information identifying 

25 an item to be purchased by the customer, receiving payment information specifying a payment 
method to be used by the customer to purchase the item, conducting a payment transaction 
with a remote payment system specified by the payment information, and providing the 
customer and the merchant with the result of the payment transaction. 

Similarly, computer program instructions for conducting electronic commerce 

30 transactions in accordance with the present invention include instructions for storing item 
information received from the merchant, instructions for issuing the merchant a reference to 
the stored item information, instructions for receiving an electronic commerce transaction 
identifier from the customer containing the reference to the stored item information issued to 

3 
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the merchant, instructions for accepting payment information from the customer, and 
instructions for conducting the electronic commerce transaction with a remote payment system. 

Brief Description of the Drawings 
5 FIGURE 1 is a high-level block diagram of an electronic commerce system according 

to an embodiment of the present invention; 

FIGURE 2 is a high-level block diagram illustrating functional components of a 
commerce server according to an embodiment of the present invention; 

FIGURE 3 is a high-level block diagram of an entry in a database associated with the 
10 commerce server according to an embodiment of the present invention; 

FIGURE 4 is a flow diagram illustrating the interactions between the customer, 
merchant, commerce server, and payment system when completing a payment transaction 
according to an embodiment of the present invention; and 

FIGURE 5 illustrates an exemplary screen display of a web page seeking payment 
1 5 information from a customer; and 

FIGURE 6 illustrates an exemplary screen display of an order confirmation web page. 

Detailed Description of the Preferred Embodiment 

As used herein, the "Internet" refers to the global network of interconnected computer 
20 systems and the "World Wide Web" ("WWW") refers to the global hypertext system using the 
Internet as its transport mechanism. A "universal resource locator" ("URL") is a reference to a 
piece of information or a software function on a computer connected to the Internet. A "web 
server" is a program that accepts requests for information framed according to the HyperText 
Transport Protocol ("HTTP"). "Web pages" are the information supplied by the web server in 
25 response to the requests. The Common Gateway Interface ("CGI") is the standard that 

describes how the web server accesses external programs, usually called "CGI programs" or 
"CGI scripts " called by a web page. Of course, the present invention is not limited to the 
Internet and may be used with any digital network supporting electronic commerce. In a non- 
Internet-based system, the terms defined above also include the non-Internet-based equivalents 
30 for communicating between the various entities described herein. 

FIG. 1 is a high-level block diagram of an electronic commerce system 100 according 
to an embodiment of the present invention. Illustrated are a customer computer (sometimes 
referred to as "the customer") 1 10, a merchant web server (sometimes referred to as "the 
merchant") 1 12, and a commerce server ("CS") 1 14, all coupled to the Internet 1 16. In a 
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typical embodiment, the customer computer 1 10 is a personal computer having, among other 
things, a processor, memory, storage device, and monitor. The customer computer 1 10 is 
coupled to the Internet 1 16 via a network connection 1 1 8. The network connection may be, for 
example, a modem coupled to an analog telephone line, a digital subscriber line, a cable 
5 modem utilizing bandwidth on a cable television coaxial cable, a high speed digital line, or any 
other communications medium. Web browsing software, such as NETSCAPE 
NAVIGATOR®, preferably executes on the client computer and sends data from the client 
computer 1 10 to the merchant web server 1 12 via the network connection 1 18 and Internet 
116. In-another embodiment, the customer computer 1 10 is a palm-top device or personal 
10 digital system communicating via radio waves with the Internet 1 16 or another electronic 
commerce system. 

The merchant web server 1 12 is preferably similar to the customer computer 110 except 
that it is has the processing power and communications 1 1 6 bandwidth to handle multiple 
simultaneous customer transactions. The merchant 1 12 sells items, such as merchandise, 

15 information, intellectual property, and/or services via a web site hosted on the merchant web 
server 112. The merchant's 112 web site may, for example, display a catalog of software 
available for purchase, allow the customer 1 10 to view flight schedules and purchase a plane 
ticket, or allow the customer 1 10 to play an online game, download a book or music, or access 
a database of information. 

20 As used herein, the terms "customer" and "merchant" depend upon the specific 

transaction being conducted. In a chain of commerce transactions, the "customer" in a first 
transaction may be a "merchant" in a second transaction. For example, the customer 1 10 may 
buy components of a product from several different vendors or merchants 1 12 using the 
electronic commerce system described herein and then, in turn, sell the combined product via 

25 the customer's own web site and the CS 1 14. 

The merchant's web site displays at least one "payment button." A payment button is a 
graphic button, a region of a larger graphic, a text string, or another form of URL link which 
the customer 1 10 may "press" by selecting it with a mouse, physical button, or other input 
device. In another embodiment, the payment button may be utilized on a non-Internet-based 

30 electronic commerce system. In such an embodiment, the payment button is considered to be 
"pressed" whenever a customer 110 expresses a desire to purchase an item. As described 
below, the payment button is pressed by the customer 1 10 when the customer 110 wishes to 
purchase and pay for an item displayed for sale on the merchant's web site. In a preferred 
embodiment, every type of item for sale on the merchant's web site has a separate payment 
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button. When a customer 1 10 wishes to purchase the product, the 1 10 customer presses the 
product's associated payment button. Then, the customer 1 10 is preferably presented with a 
menu allowing the customer 1 10 to specify attributes, such as quantity or duration, of the items 
that the customer 1 1 0 wishes to purchase. 
5 In another embodiment, the merchant web site has only one payment button or has only 

one payment button for each class of items for sale. In this embodiment, the customer 1 1 0 is 
preferably presented with a menu of choices after pressing the payment button. For example, 
the menu of choices may ask the customer 1 10 to identify a specific product or an attribute of a 
product, like color, that the customer 1 10 wishes to purchase. 
10 Every payment button has an associated URL that points to information in the CS 114. 

Preferably, a database key that uniquely identifies the merchant 1 12 and/or item for sale is 
encoded within the URL. When the customer 110 presses the payment button, the customer 
1 10 is redirected to a web page provided by the CS 1 14 and specific to the merchant 1 12 
and/or item. 

15 In one embodiment, the CS 1 14 queries the customer for the quantity or duration of the 

item that the customer 1 10 wishes to purchase and payment information. The CS 1 14 receives 
the customer's responses and conducts the electronic commerce transaction according to 
payment processing rules and delivery options specified by the merchant 1 12. The CS 1 14 
records the transaction in its database and notifies the customer and merchant whether the 

20 transaction was successful. Accordingly, the merchant 1 12 is relieved of the responsibility of 
conducting the electronic commerce transaction with the customer 110. 

FIG. 2 is a high-level block diagram illustrating functional components of the CS 114 
and also illustrating a remote payment system 222 and a remote merchant 223 according to a 
preferred embodiment of the present invention. The CS 1 14 is preferably similar to the 

25 customer 1 10 and merchant 112 computers, except that the CS 1 14 has enough processing 
power and Internet 116 bandwidth to support many simultaneous payment button transactions 
as described herein. The functionality of the CS 1 14 described herein may be performed by 
hardware or software modules within the CS 1 14. In one embodiment of the present invention, 
the functionality of the CS 1 14 is provided by software applications executing on INTEL x86- 

30 or SUN MICROSYSTEMS SPARC-compatible hardware under control of MICROSOFT 
WINDOWS NT or a derivative of the UNIX operating system, such as SOLARIS 2.5.1. In 
another embodiment of the present invention, the functionality of the CS 1 14 is provided by a 
distributed computing system as described below. 

6 
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The remote payment system 222 is preferably a third-party payment gateway or system. 
The gateway or system is preferably connected to a financial transaction network, which, in 
turn, typically links to computers at banks and other financial institutions for approval and 
settlement of electronic commerce transactions. Typical gateways or systems may include 
5 CYBERCASH, e-CASH, MONDEX, or SET. While only one payment system 222 is 
illustrated in FIG. 2, the CS 1 14 may be in communication with many different remote 
payment systems 222, either through a secure link on the Internet 1 1 6 or a dedicated secure 
link. Each payment system has an applications programming interface ("API"). By using the 
API, the CS 1 1 4 communicates with the payment system 222 and performs secure and 

10 verifiable payment transactions. 

The remote merchant 223 is preferably a merchant selling items via a web site as 
described above. The remote merchant 223 may have an account on the CS 1 14 or the 
merchant 223 may have an interface for selling items similar to the remote payment system 
222. In general, the remote merchant 223 is included in FIG. 2 to illustrate that the customer's 

15 110 electronic commerce transaction performed by the CS 1 14 may contact a remote payment 
system 222 and/or a remote merchant 223. 

The CS 1 14 includes a payment button transaction engine 210 which is coupled to a 
database 212 and a web server 214. A firewall 216 preferably sits between the web server 216 
and the transaction engine 210. While these functional components are illustrated in FIG. 2 as 

20 discrete entities, the CS 1 14 may be executed on a distributed computer system having a 
plurality of engines, databases, and web servers working together the perform the functions 
described herein. For example, one embodiment of the CS 1 14 uses multiple transaction 
engines 210 and web servers 214 and a single distributed database 212, thereby providing 
scalability to the CS 1 14. The number of web servers 214 and transaction engines 210 depends 

25 on the actual system load and the desire to achieve better performance through balancing the 
transaction load across the system. 

The payment button transaction engine 210 includes a rules module 218 that controls 
the interactions and flows of information necessary to complete a payment transaction. In 
addition, the transaction engine 210 preferably includes a Payment Application Programming 

30 Interface ("PAPI") module 220 enabling communication between the CS 1 14 and the remote 
payment systems 222 and merchants 223. The PAPI module 220 abstracts the different APIs 
of each payment system 222 and merchant 223 into a single, higher level, PAPI that can 
interface with each of the payment systems 222 and merchants 223. The transaction engine 
210 performs payment transactions with a payment system 222 or merchant 223 by making 
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calls to the PAPI. The PAPI abstraction module 220 translates these calls into the specific API 
of the payment system 222 or merchant 223 being used for that transaction. The PAPI 
abstraction module 220 also translates data received from the payment system 222 or merchant 
223 into the format utilized by the transaction engine 210. Accordingly, the PAPI abstraction 
5 module 220 allows support for new payment systems 222 and merchants 223 to be added to the 
CS 1 14 by merely creating a new PAPI to payment system or merchant API mapping in the 
PAPI abstraction module 220. 

The payment button store module ( <l PB store") 224, in combination with the web server 
214, allows a merchant 1 12 to obtain a payment button. The web server 214 is preferably an 

1 0 industry standard web server such as the NETSCAPE ENTERPRISE SERVER or the 

APACHE web server. The web server 214 provides secure communication with the customer 
110 and preferably uses industry standard technologies including HyperText Markup Language 
("HTML"), and HTTP to deliver information to the customer 110. In addition, the web server 
preferably uses industry standard encryption techniques, including secure HTTP ("S-HTTP") 

1 5 and the secure sockets layer ("SSL"), to ensure that communications with the customer 1 10 are 
private. The firewall 216 allows only authorized communications between the web server 214 
and the transaction engine 2 1 0 and ensures that a malicious user cannot access or corrupt the 
transaction engine 210. 

The PB store 224 allows the merchant to purchase payment buttons and add product 

20 descriptions, merchant configurations, and other information to the database 212. In a 

preferred embodiment of the present invention, the merchant 1 12 accesses the PB store through 
a web site on the web server 214. The PB store module 224 captures the merchant 112 actions 
on the web server 214 and creates the appropriate entries in the database 212. 

In one embodiment of the present invention, the PB store web site describes the 

25 payment button mechanism, the services offered by the payment button vendor, and the costs 
of the services. In addition, the web site preferably has a merchant registration form 226 for 
registering new merchants, a merchant renewal form 228 for renewing merchant registrations, 
and a payment button generation form 230 for issuing payment buttons to registered 
merchants. The forms preferably include CGI programs for performing the functionality 

30 described herein. 

The merchant registration form 226 allows the merchant 1 12 to input information 
identifying the merchant 1 12 and includes a payment button with which the merchant 1 12 can 
pay a registration fee. After the fee payment is verified, the merchant 1 12 is preferably issued 
a login/password pair and an account with the CS 1 14 through which the merchant 1 12 can 
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access the payment button generation form and maintain the merchant's account. Similarly, 
the merchant renewal form 228 preferably includes a payment button with which the merchant 
1 12 can pay a renewal fee. 

The payment button generation form 230 allows the merchant 1 12 to enter item 
5 description data, such as item names and descriptions, prices, types, and delivery options, and 
payment processing rules, such as supported credit cards, payment systems, and currencies. In 
addition, the payment processing rules may rank the payment systems in order of preference, 
describe when payment is required (e.g., the merchant may require billing after 90 days), 
and/or describe the quantity or duration of an item available for a certain price. In one 
10 embodiment of the present invention, the merchant 1 12 enters the item description data and 
payment processing rules by uploading a file to web site having the information in a 
standardized format. 

When entry of this data is completed, the payment button generation form 230 sends 
the data to the transaction engine 210, which stores the information in the database 212 at a 

15 location specified by a key. The transaction engine 210 passes the key back to the PB store 
web site, which provides the merchant with a payment button download page displaying the 
results of the payment button generation transaction. If the transaction was successful, the 
payment button download page includes the payment button issued to the merchant 1 12. The 
payment button has an associated URL that specifies the key. Accordingly, little or no 

20 engineering effort is required to maintain each merchant configuration on the CS 1 14. 

In one embodiment of the present invention, there are multiple PB store web sites 
communicating with the database 212 through the transaction engine 210. When a payment 
button is created, the transaction engine 210 creates a field in the database 212 entry specifying 
the PB store that generated the payment button. Accordingly, payment buttons may be 

25 "branded" among different payment button vendors. 

The database 212 is preferably a robust relational database. A preferred embodiment of 
the present invention uses the ORACLE 7 database to implement the functionality described 
herein. The database 212 stores item descriptions, payment processing rules, and other 
information necessary to complete a payment transaction on behalf of a merchant 1 12. This 

30 merchant information is preferably accessed in the database by using a key assigned to each 
merchant 1 12 and/or item for sale. The database 212 is also used as a repository of transaction 
information including authorization logs, payment status and completion records, and other 
information required by the merchant 1 12 and the CS 1 14. 

9 
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FIG. 3 is a high-level block diagram of functional components within the database 212. 
Illustrated therein are a database entry 300 including a primary entry 3 1 0 linked to at least one 
of three types of item entries 312, 314. 316. The primary entry 310 is the entry identified by 
the key provided to the merchant 1 12. Accordingly, the primary entry 310 is typically 
5 accessed either when the merchant 1 1 2 provides the key while using the PB store web site or 
when the customer 110 uses the URL provided by a payment button to purchase the item 
identified in the database entry 310. 

The primary entry 310 contains a field 318 storing the payment processing rules for the 
item as specified by the merchant 112 through the PB store. The primary entry 310 also 
1 0 contains a field 320 holding item type information as specified by the merchant 112. The item 
type information preferably describes the item attributes input by the merchant 1 12. In 
addition, the item type information field 320 preferably contains at least one link to another 
database entry 312, 314, 316 describing delivery options for the item. 

The available delivery options for an item depend upon the type of item. FIG. 3 
15 illustrates three database entries 312, 314, 316 describing delivery options for hard, soft, and 
online items. However, an embodiment of the present invention may have many different 
types of items and corresponding delivery options. A hard item is typically a manufactured 
physical product such as clothing, a book, or a machine part. Accordingly, the entry 312 
holding delivery options 322 may list various shipping methods and companies available for 
20 delivering the hard item to the customer 1 1 0. 

A soft item, in contrast, is typically intangible intellectual property such as music, 
electronic books, or software. For example, the soft item may be a streaming music file that 
can be played by the customer 1 10. Accordingly, the entry 314 holding delivery options 324 
may list a URL or electronic key that can be provided to the customer to effectuate the 
25 purchase. For example, the options 324 may provide instructions for initiating an FTP session 
to download the purchased soft item to the customer's 110 computer system. 

An online item is typically access to an online service or other software executing 
remotely from the customer 110. For example, the online item may be access to an electronic 
database of information or an online game. Accordingly, the entry 316 holding delivery 
30 options 326 preferably includes instructions for allowing the customer 1 1 0 to access the online 
item. For example, the options 326 may provide instructions for initiating a telnet session with 
an electronic database for a limited duration of time. 

FIG. 4 is a flow diagram illustrating the interactions between the customer 1 10, 
merchant 1 12, CS 1 14, database 212 and a payment system 222 when completing a payment 

10 
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transaction according to a preferred embodiment of the present invention. In the flow diagram, 
time flows from the top of the diagram to the bottom and horizontal lines represent 
communications between the various entities. FIG. 4 illustrates only major interactions 
between the entities and does not represent every interaction. In addition, FIG. 4 illustrates a 
5 simple case of the present invention wherein the merchant's 112 payment processing rules 
specify that the payment transaction should be processed at the time the customer's 1 10 order 
is received. 

Initially, the customer 1 10 is browsing the merchant's web site and decides to purchase 
an item by pressing 410 the associated payment button. In response to the press, the 

10 merchant's web server 1 12 redirects 412 the customer's browser to the location on the CS 1 14 
specified by the URL associated with the payment button. The customer's browser fetches 414 
the referenced page from the CS 1 14. 

The CS 1 14 parses the URL received from the customer 1 10 for the database 212 key 
corresponding to the item that the customer 1 10 wishes to purchase. Using this key, the CS 

15 114 accesses 4 1 6 the database 212 and dynamically generates a web page indicating the 
attributes and payment options available for the item as defined by the merchant 112. In 
addition, the CS 1 14 preferably determines the language utilized by the customer 1 10 and 
currencies supported by the merchant 112 and modifies the web page accordingly. This 
generated web page is sent 418 to the customer 1 10. FIG. 5 illustrates an exemplary screen 

20 display 500 of the web page seeking payment information from the customer 1 10. 

The customer selects the desired item attributes and payment service, enters any 
necessary payment information, such as a credit card or account number, and transmits 420 
these data to the CS 1 14. The CS 1 14 stores 422 the received data in the database 212 and 
contacts the selected payment system 222. As described above, the CS 1 14 preferably uses the 

25 PAPI module 220 to translate transaction calls made by the transaction engine 210 into the API 
of the selected payment system 222. The CS 1 14 preferably stores 426 records of all 
communications with the payment system 222, customer 110, and merchant 1 12 in the 
database 212. Therefore, the database 212 can be used to reconstruct transaction histories in 
order to provide error tracking and accounting services. If the payment system 222 rejects the 

30 transaction, the CS 1 14 publishes a web page to the customer indicating this result and 
presenting alternative payment methods, if any (this interaction is not shown in FIG. 4). 

If the payment system 222 approves the transaction, the CS dynamically generates a 
web page containing payment status information and publishes 428 this information to the 
customer 1 10. This page preferably contains a receipt or confirmation number generated by 

11 
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the CS 1 14. In a preferred embodiment of the present invention, the confirmation number is a 
unique number encoding transaction, session, and merchant identifications and a time and date 
stamp. This confirmation number is preferably a key to a database entry holding the 
transaction information and can be used later by the merchant 1 12 and customer 1 10 to confirm 
5 payment, to query the CS 1 14 for payment status information, and to use the CS 1 14 to query 
the payment system for account status information. The web page also preferably contains any 
other information required by the merchant 1 12 and a link to a confirmation page on the 
merchant's web site 112. FIG. 6 illustrates an exemplary screen display 600 of an order 
confirmation web page. 

10 The CS 1 14 also notifies 428 the merchant 1 12 that payment was accepted and provides 

the same receipt or confirmation number as was provided to the customer 110. In one 
embodiment, this notification is performed via a secure electronic mail message. Accordingly, 
both the customer 1 10 and merchant 1 12 are notified that the purchase was made. 

Finally, the customer 110 fetches 430 the confirmation web page on the merchant's 

15 web site. Preferably, this web page provides the customer 1 10 with additional information 
about the purchase or any other information which the merchant 112 desires to provide. 

In summary, the present invention is a system, method, and computer program 
instructions for conducting electronic commerce transactions via the Internet or any electronic 
communication system. The merchant 1 12 opens an account on the CS 1 14 and supplies 

20 information about items sold by the merchant 112. The CS i 14 stores this information in a 
database 212 entry and issues the merchant 112 a URL containing the key to database entry. 
The merchant 112 supplies this URL to customers wishing to purchase an item, causing a 
customer 1 10 to be connected to the CS 1 14. The CS 1 14 collects payment information from 
the customer 110, conducts the electronic commerce transaction with a remote payment system 

25 222, and notifies the customer 1 10 and merchant 1 12 of the result. 
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Claims 

I claim: 

1 . A computer system for supporting electronic commerce transactions between a 
customer and a remote merchant, the computer system comprising: 

5 a database having an entry including merchant information identifying an item 

offered for sale by the remote merchant; and 
a transaction engine in communication with the database and a remote payment 
system for performing an electronic commerce transaction, the transaction 
engine comprising: 

10 a first module for receiving an electronic commerce transaction identifier 

from the customer, the electronic commerce transaction identifier 

specifying the entry in the database; 
a second module for accepting payment information from the customer, the 

payment information identifying the remote payment system; and 
1 5 a third module for performing the electronic commerce transaction with the 

remote payment system using the payment information received 

from the customer. 

2. The computer system of claim 1, wherein the transaction engine further 
comprises: 

20 a fourth module for notifying the remote merchant and the customer of a result of 

the electronic commerce transaction. 

3. The computer system of claim 1 , further comprising: 

a web server in communication with the transaction engine for communicating with 
the remote merchant and customer; and 
25 a firewall between the web server and the transaction engine for securing 

communications between the web server and the transaction engine. 

4. The computer system of claim 3, wherein the transaction engine further 
comprises: 

a fifth module for dynamically generating a web page from the entry in the database 

30 and providing the web page to the customer via the web server, the web 

page providing information about the item offered for sale by the remote 
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merchant and facilitating collection of the payment information from the 
customer. 

5. The computer system of claim 3, wherein the computer system further 
comprises: 

5 a sixth module for accepting the merchant information identifying the item offered 

for sale by the remote merchant via the web server, creating the database 
entry for holding the merchant information, and providing the remote 
merchant with a reference to the database entry. 

6. The computer system of claim 1, wherein the electronic commerce transaction 
10 identifier is a URL identifying the computer system and including a key to the entry in the 

database. 

7. The computer system of claim 1, wherein the database further comprises: 

an entry specifying payment processing rules defined by the remote merchant; and 
an entry specifying delivery options for the item offered for sale by the remote 
15 merchant. 

8. The computer system of claim 1 , wherein there are a plurality of available 
remote payment systems and wherein the second module for accepting payment information 
from the customer accepts payment information identifying one of the available remote 
payment systems. 

20 9. The computer system of claim 1 , wherein the transaction engine is executed by 

a plurality of distributed computer systems. 

1 0. A method of conducting electronic commerce between a remote customer and a 
remote merchant, the method comprising the steps of: 

receiving information identifying an item to be purchased by the remote customer; 
25 receiving payment information specifying a payment method to be used by the 

remote customer to purchase the item; 
conducting a payment transaction with a remote payment system specified by the 
payment information; and 
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providing the remote customer and the remote merchant with a result of the 
payment transaction. 

1 1 . The method of claim 1 0, further comprising the steps of: 

receiving information about the item to be purchased from the remote merchant; 
5 storing the information about the item to be purchased at a specified location; and 

providing the remote merchant with a reference to the specified location. 

12. The method of claim 1 1 , wherein the remote merchant provides the reference to 
the specified location to the remote customer responsive to the remote customer desiring to 
purchase the item. 

10 13. The method of claim 10, further comprising the step of: 

providing the remote customer with a list of item attributes from which the 
customer can select. 

14. The method of claim 10, wherein the step of receiving information identifying 
the item to be purchased by the remote customer comprises the steps of: 

15 receiving payment processing rules specifying payment options available for 

purchasing the item; and 
receiving delivery options for the item. 

15. A computer-readable medium having computer instructions encoded thereon for 
conducting electronic commerce transactions between a remote merchant and a remote 

20 customer, the computer instructions comprising: 

instructions for storing item information received from the remote merchant; 
instructions for issuing the remote merchant a reference to the stored item 
information; 

instructions for receiving an electronic commerce transaction identifier from the 
25 remote customer containing the reference to the stored item information 

issued to the remote merchant; 
instructions for accepting payment information from the remote customer, the 

payment information identifying a remote payment system; and 
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instructions for conducting the electronic commerce transaction with the remote 
payment system using the payment information received from the remote 
customer. 

16. The computer-readable medium of claim 15, wherein the instructions further 
5 comprise: 

instructions for notifying the remote merchant and the remote customer of a result 
of the electronic commerce transaction. 

17. The computer-readable medium of claim 15, wherein the instructions for storing 
item information received from the remote merchant comprise: 

10 instructions for receiving payment processing rules from the remote merchant 

specifying payment options for the electronic commerce transaction; and 
instructions for receiving delivery rules from the remote merchant specifying 
delivery options for the electronic commerce transaction. 
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PAYMENT DETAILS 




PLEASE REVIEW THIS PAGE AND ENSURE IT IS CORRECT, 
BEFORE COMPLETING YOUR PAYMENT DETAILS. 



PRODUCTS ORDERED 



SKU QTY ITEMS UNIT PRICE EXTENDED PRICE 

2121 2 SPROCKET $8.99 $17.98 

SUBTOTAL: $17.98 
SHIPPING: $ 3.95 
TAX: $ 1.72 

TOTAL: $23.65 



BILLING ADDRESS 



FIRST NAME: 
LAST NAME: 
COMPANY: 
ADDRESS 1: 
ADDRESS2: 
CITY: 
STATE: 
ZIP: 



SHIPPING ADDRESS 



JOE 

BLOGGS 

GLOBAL BAKING COMPANY 
2252 N. PETERS RD. 

SAN JOSE 
CA 

96025-5123 



PAYMENT INFORMATION 



PAYMENT TYPE: MASTERCARD 
NAMEAS IT APPEARS ON CARD * 1 

NUMBER * I - 

EXPIRATION DATE * L_J/I J 

| MAKE CORRECTIONS | | PROCESS ORDER | 
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RECEIPT 




- - THANK YOU FOR YOUR ORDER - - 
RECEIPT NUMBER: 1587-8029-5 


GLOBAL SPROKETS COMPANY INC. 

2243 E. WISTENA WAY, BOSTON, MA 24248, USA 

EMAIL: INFO@SPROKETS.COM. WEB: HTTP//WWW.SPROKETS.COM 


I 






PRODUCTS ORDERED 




I 




SKU QTY ITEMS UNIT PRICE TOTAL PRICE 
2121 2 SPROCKET $8.99 $17.98 

SUBTOTAL: $17.98 
SHIPPING: $ 3.95 
TAX: $ 1.72 
TOTAL: $23.65 






| BILLING ADDRESS 




SHIPPING ADDRESS 




FIRST NAME: 
LAST NAME: 
COMPANY: 
ADDRESS 1: 
ADDRESS2: 
CITY: 
STATE: 
ZIP: 


JOE 

BLOGGS 

GLOBAL BAKING COMPANY 
2252 N. PETERS RD. 

SAN JOSE 
CA 

96025-5123 
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PAYMENT INFORMATION 


I 




PAYMENT TYPE: MASTERCARD 
YOUR CARD HAS BEEN CHARGED: $23.65 






I 




CUSTOMER INFORMATION 


I 






WE AIM TO SHIP ITEMS WITHIN 10 DAYS 
THANK YOU FOR YOUR ORDER! 










RETURN TO SITE 
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